Product Code Database
Example Keywords: silk -underpants $14
   » » Wiki: Ping (networking Utility)
Tag Wiki 'Ping (networking Utility)'.
Tag

Ping is a administration used to test the reachability of a host on an Internet Protocol (IP) network. It is available in a wide range of including most embedded network administration software.

Ping measures the for messages sent from the originating host to a destination computer that are echoed back to the source. The name comes from terminology that sends a pulse of sound and listens for the to detect objects under water.

Ping operates by means of Internet Control Message Protocol (ICMP) . Pinging involves sending an ICMP echo request to the target host and waiting for an ICMP echo reply. The program reports errors, , and a statistical summary of the results, typically including the minimum, maximum, the mean round-trip times, and standard deviation of the mean.

Command-line options and terminal output vary by implementation. Options may include the size of the payload, count of tests, limits for the number of network hops (TTL) that probes traverse, interval between the requests and time to wait for a response. Many systems provide a companion utility ping6, for testing on Internet Protocol version 6 (IPv6) networks, which implement ICMPv6.


History
The ping utility was written by in December 1983 during his employment at the Ballistic Research Laboratory, now the US Army Research Laboratory. A remark by David Mills on using ICMP echo packets for IP network diagnosis and measurements prompted Muuss to create the utility to troubleshoot network problems. The author named it after the sound that makes since its methodology is analogous to sonar's echolocation.
(1994). 9780201547771, .
The Packet InterNet Groper for PING has been used for over 30 years. Muuss says that, from his point of view, PING was not intended as an acronym but he has acknowledged Mills' expansion of the name. The first released version was public domain software; all subsequent versions have been licensed under the . Ping was first included in 4.3BSD. The version was developed by Erick Engelke and is licensed under the . Tim Crawford developed the version. It is licensed under the .

Any host must process ICMP echo requests and issue echo replies in return.


Invocation example
The following is the output of running ping on Linux for sending five probes (1-second interval by default, configurable via -i option) to the target host www.example.com:

$ ping -c 5 www.example.com

PING www.example.com (93.184.216.34): 56 data bytes 64 bytes from 93.184.216.34: icmp_seq=0 ttl=56 time=11.632 ms 64 bytes from 93.184.216.34: icmp_seq=1 ttl=56 time=11.726 ms 64 bytes from 93.184.216.34: icmp_seq=2 ttl=56 time=10.683 ms 64 bytes from 93.184.216.34: icmp_seq=3 ttl=56 time=9.674 ms 64 bytes from 93.184.216.34: icmp_seq=4 ttl=56 time=11.127 ms

--- www.example.com ping statistics --- 5 packets transmitted, 5 packets received, 0.0% packet loss round-trip min/avg/max/stddev = 9.674/10.968/11.726/0.748 ms

The output lists each probe message and the results obtained. Finally, it lists the statistics of the entire test. In this example, the shortest was 9.674 ms, the average was 10.968 ms, and the maximum value was 11.726 ms. The measurement had a standard deviation of 0.748 ms.


Error indications
In cases of no response from the target host, most implementations display either nothing or periodically print notifications about timing out. Possible ping results indicating a problem include the following:
  • or host, network or protocol unreachable
  • source route failed
  • fragmentation needed
  • or destination network/host unknown
  • source host is isolated
  • communication with destination network administratively prohibited
  • communication with destination host administratively prohibited
  • for this ToS the destination network is unreachable
  • for this ToS the destination host is unreachable
  • communication administratively prohibited
  • host precedence violation
  • precedence cutoff in effect

In case of error, the target host or an intermediate router sends back an ICMP error message, for example host unreachable or TTL exceeded in transit. In addition, these messages include the first eight bytes of the original message (in this case header of the ICMP echo request, including the quench value), so the ping utility can match responses to originating queries.


Message format

ICMP packet transported with IPv4
An ICMP packet transported with IPv4 looks like this.

Most Linux systems use a unique Identifier for every ping process, and Sequence number is an increasing number within that process. Windows uses a fixed Identifier, which varies between Windows versions, and a Sequence number that is only reset at boot time.

The Echo Reply is returned as:


ICMPv6 packet transported with IPv6
An ICMP packet transported with IPv6 looks like this.

Most Linux systems use a unique Identifier for every ping process, and Sequence number is an increasing number within that process. Windows uses a fixed Identifier, which varies between Windows versions, and a Sequence number that is only reset at boot time.

The Echo Reply is returned as:


Payload
The payload of the packet is generally filled with characters, as the output of the utility shows in the last 32 bytes of the following example (after the eight-byte ICMP header starting with ): 16:24:47.966461 IP (tos 0x0, ttl 128, id 15103, offset 0, flags none, proto: ICMP (1), length: 60) 192.168.146.22 > 192.168.144.5: ICMP echo request, id 1, seq 38, length 40
      0x0000:  4500 003c 3aff 0000 8001 5c55 c0a8 9216  E..<:.....\U....
      0x0010:  c0a8 9005 0800 4d35 0001 0026 6162 6364  ......M5...&abcd
      0x0020:  6566 6768 696a 6b6c 6d6e 6f70 7172 7374  efghijklmnopqrst
      0x0030:  7576 7761 6263 6465 6667 6869            uvwabcdefghi
     
The payload may include a timestamp indicating the time of transmission and a sequence number, which are not found in this example. This allows ping to compute the round-trip time in a manner without needing to record the time of transmission of each packet.

The payload may also include a magic packet for the protocol, but the minimum payload, in that case, is longer than shown. The Echo Request typically does not receive any reply if the host was sleeping in hibernation state, but the host still wakes up from sleep state if its interface is configured to accept wakeup requests. If the host is already active and configured to allow replies to incoming ICMP Echo Request packets, the returned reply should include the same payload. This may be used to detect that the remote host was effectively woken up, by repeating a new request after some delay to allow the host to resume its network services. If the host was just sleeping in low power active state, a single request wakes up that host just enough to allow its Echo Reply service to reply instantly if that service was enabled. The host does not need to wake up all devices completely and may return to low-power mode after a short delay. Such configuration may be used to avoid a host to enter in hibernation state, with much longer wake-up delay, after some time passed in low power active mode.

A packet including IP and ICMP headers must not be greater than the maximum transmission unit of the network, or risk being .


Security loopholes
To conduct a denial-of-service attack, an attacker may send ping requests as fast as possible, possibly overwhelming the victim with ICMP echo requests. This technique is called a .

Ping requests to multiple addresses, , may be used to obtain a list of all hosts on a network.


See also


Further reading


External links

Page 1 of 1
1
Page 1 of 1
1

Account

Social:
Pages:  ..   .. 
Items:  .. 

Navigation

General: Atom Feed Atom Feed  .. 
Help:  ..   .. 
Category:  ..   .. 
Media:  ..   .. 
Posts:  ..   ..   .. 

Statistics

Page:  .. 
Summary:  .. 
1 Tags
10/10 Page Rank
5 Page Refs